﻿2026-06-07T23:26:21.0310816Z ##[group]Run ./traceable-reqs lint || true
2026-06-07T23:26:21.0310972Z [36;1m./traceable-reqs lint || true[0m
2026-06-07T23:26:21.0323875Z shell: /usr/bin/bash -e {0}
2026-06-07T23:26:21.0323964Z ##[endgroup]
2026-06-07T23:26:21.0480578Z Requirement quality findings (55); 166 requirements queued for agent review:
2026-06-07T23:26:21.0481532Z   [must] requirement_quality REQ-API-1 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0481872Z   [must] requirement_quality REQ-CLI-1 criterion=length — title is 47 words; want 3..=25
2026-06-07T23:26:21.0482210Z   [must] requirement_quality REQ-CLI-2 criterion=length — title is 37 words; want 3..=25
2026-06-07T23:26:21.0482518Z   [must] requirement_quality REQ-CLI-3 criterion=length — title is 37 words; want 3..=25
2026-06-07T23:26:21.0482893Z   [must] requirement_quality REQ-CONSENT-1 criterion=length — title is 41 words; want 3..=25
2026-06-07T23:26:21.0483450Z   [must] requirement_quality REQ-CONSENT-2 criterion=length — title is 37 words; want 3..=25
2026-06-07T23:26:21.0484419Z   [must] requirement_quality REQ-CONV-1 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0485046Z   [must] requirement_quality REQ-CONV-1 criterion=length — title is 73 words; want 3..=25
2026-06-07T23:26:21.0485897Z   [must] requirement_quality REQ-CONV-2 criterion=length — title is 47 words; want 3..=25
2026-06-07T23:26:21.0486537Z   [must] requirement_quality REQ-DAEMON-5 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0487057Z   [must] requirement_quality REQ-DAEMON-5 criterion=length — title is 64 words; want 3..=25
2026-06-07T23:26:21.0487647Z   [must] requirement_quality REQ-HAZARD-CONFLICT-BOTH-PRESERVED criterion=length — title is 29 words; want 3..=25
2026-06-07T23:26:21.0488065Z   [must] requirement_quality REQ-HAZARD-DAEMON-SCHED-NONBLOCKING criterion=length — title is 32 words; want 3..=25
2026-06-07T23:26:21.0488488Z   [must] requirement_quality REQ-HAZARD-DETACHED-PIPE-INHERIT criterion=length — title is 52 words; want 3..=25
2026-06-07T23:26:21.0489009Z   [must] requirement_quality REQ-HAZARD-ELEVATED-DAEMON-SPAWN criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0489403Z   [must] requirement_quality REQ-HAZARD-ELEVATED-DAEMON-SPAWN criterion=length — title is 58 words; want 3..=25
2026-06-07T23:26:21.0489915Z   [must] requirement_quality REQ-HAZARD-ENVELOPE-PARSER-SAFE criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0490524Z   [must] requirement_quality REQ-HAZARD-EPOCH-RESET criterion=length — title is 60 words; want 3..=25
2026-06-07T23:26:21.0491095Z   [must] requirement_quality REQ-HAZARD-GEN-START-NOW criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0491516Z   [must] requirement_quality REQ-HAZARD-INSTANT-UNDERFLOW criterion=length — title is 30 words; want 3..=25
2026-06-07T23:26:21.0491888Z   [must] requirement_quality REQ-HAZARD-PAIR-RATE-LIMIT criterion=length — title is 37 words; want 3..=25
2026-06-07T23:26:21.0492254Z   [must] requirement_quality REQ-HAZARD-PAIR-SEED-ROTATION criterion=length — title is 33 words; want 3..=25
2026-06-07T23:26:21.0492737Z   [must] requirement_quality REQ-HAZARD-PAIR-TRANSCRIPT-BIND criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0493229Z   [must] requirement_quality REQ-HAZARD-PSYCHE-OUTBOUND-PROXY criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0493624Z   [must] requirement_quality REQ-HAZARD-PSYCHE-OUTBOUND-PROXY criterion=length — title is 27 words; want 3..=25
2026-06-07T23:26:21.0494097Z   [must] requirement_quality REQ-HAZARD-REGISTRY-GHOST-ROWS criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0494463Z   [must] requirement_quality REQ-HAZARD-REGISTRY-GHOST-ROWS criterion=length — title is 66 words; want 3..=25
2026-06-07T23:26:21.0494984Z   [must] requirement_quality REQ-HAZARD-SUDO-SECURE-PATH criterion=length — title is 43 words; want 3..=25
2026-06-07T23:26:21.0495337Z   [must] requirement_quality REQ-HAZARD-WAN-ORIGIN-AUTH criterion=length — title is 37 words; want 3..=25
2026-06-07T23:26:21.0495626Z   [must] requirement_quality REQ-INST-15 criterion=length — title is 32 words; want 3..=25
2026-06-07T23:26:21.0495923Z   [must] requirement_quality REQ-INSTALL-2 criterion=length — title is 2 word(s); want 3..=25
2026-06-07T23:26:21.0496353Z   [must] requirement_quality REQ-INSTALL-6 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0497182Z   [must] requirement_quality REQ-INSTALL-6 criterion=length — title is 56 words; want 3..=25
2026-06-07T23:26:21.0497942Z   [must] requirement_quality REQ-INSTALL-7 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0498644Z   [must] requirement_quality REQ-INSTALL-7 criterion=length — title is 50 words; want 3..=25
2026-06-07T23:26:21.0499244Z   [must] requirement_quality REQ-INSTALL-8 criterion=length — title is 55 words; want 3..=25
2026-06-07T23:26:21.0499963Z   [must] requirement_quality REQ-MANIFEST-1 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0500766Z   [must] requirement_quality REQ-MIGRATE-1 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0501461Z   [must] requirement_quality REQ-MSG-4 criterion=length — title is 31 words; want 3..=25
2026-06-07T23:26:21.0502114Z   [must] requirement_quality REQ-PAIR-8 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0502692Z   [must] requirement_quality REQ-PAIR-8 criterion=length — title is 67 words; want 3..=25
2026-06-07T23:26:21.0503277Z   [must] requirement_quality REQ-PRES-1 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0503874Z   [must] requirement_quality REQ-PRES-1 criterion=length — title is 48 words; want 3..=25
2026-06-07T23:26:21.0504380Z   [must] requirement_quality REQ-SEAM-SPAWN criterion=length — title is 2 word(s); want 3..=25
2026-06-07T23:26:21.0504895Z   [must] requirement_quality REQ-SHELL-1 criterion=length — title is 36 words; want 3..=25
2026-06-07T23:26:21.0505385Z   [must] requirement_quality REQ-SHELL-2 criterion=length — title is 49 words; want 3..=25
2026-06-07T23:26:21.0505992Z   [must] requirement_quality REQ-STORE-1 criterion=length — title is 34 words; want 3..=25
2026-06-07T23:26:21.0506531Z   [must] requirement_quality REQ-SUBNET-5 criterion=length — title is 52 words; want 3..=25
2026-06-07T23:26:21.0507271Z   [must] requirement_quality REQ-SUBNET-6 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0507881Z   [must] requirement_quality REQ-SUBNET-6 criterion=length — title is 38 words; want 3..=25
2026-06-07T23:26:21.0508484Z   [must] requirement_quality REQ-SUBNET-7 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0509065Z   [must] requirement_quality REQ-SUBNET-7 criterion=length — title is 75 words; want 3..=25
2026-06-07T23:26:21.0509566Z   [must] requirement_quality REQ-SUBNET-8 criterion=length — title is 53 words; want 3..=25
2026-06-07T23:26:21.0510152Z   [must] requirement_quality REQ-UPD-6 criterion=contains-and — title contains ' and ' — may smuggle multiple capabilities
2026-06-07T23:26:21.0510725Z   [must] requirement_quality REQ-UPD-6 criterion=length — title is 32 words; want 3..=25
2026-06-07T23:26:21.0511002Z 
2026-06-07T23:26:21.0511111Z # Requirement quality review
2026-06-07T23:26:21.0511263Z 
2026-06-07T23:26:21.0511458Z You are reviewing 166 requirement(s) from `traceable-reqs.toml` against a quality
2026-06-07T23:26:21.0511881Z rubric. Deterministic checks (length, contains-and, tbd-todo, duplicate-titles,
2026-06-07T23:26:21.0512440Z trailing-etc) have already run and surfaced as `requirement_quality` findings on
2026-06-07T23:26:21.0512812Z this command's output. Your task is the rubric items below.
2026-06-07T23:26:21.0513022Z 
2026-06-07T23:26:21.0513122Z ## Rubric
2026-06-07T23:26:21.0513237Z 
2026-06-07T23:26:21.0513508Z - **singular** — describes one capability; no smuggled "and"/"or" across distinct actions.
2026-06-07T23:26:21.0514018Z - **verifiable** — states an observable behavior a test or reviewer could confirm.
2026-06-07T23:26:21.0514472Z - **atomic** — cannot be split into two requirements without losing meaning.
2026-06-07T23:26:21.0514845Z - **active-voice** — clear subject and active verb.
2026-06-07T23:26:21.0515035Z 
2026-06-07T23:26:21.0515278Z If a criterion is borderline or doesn't apply, abstain — only emit findings for
2026-06-07T23:26:21.0515593Z clear concerns.
2026-06-07T23:26:21.0515722Z 
2026-06-07T23:26:21.0515818Z ## Requirements
2026-06-07T23:26:21.0515950Z 
2026-06-07T23:26:21.0516041Z ### REQ-ARCH-1
2026-06-07T23:26:21.0516237Z - Title: Many small acyclically-layered crates
2026-06-07T23:26:21.0516496Z - Required stages: impl
2026-06-07T23:26:21.0516632Z 
2026-06-07T23:26:21.0516721Z ### REQ-ARCH-2
2026-06-07T23:26:21.0517038Z - Title: Public SDK surface is spt-proto, spt-runtime, spt-msg
2026-06-07T23:26:21.0517678Z - Required stages: impl
2026-06-07T23:26:21.0517898Z 
2026-06-07T23:26:21.0518022Z ### REQ-ARCH-3
2026-06-07T23:26:21.0518390Z - Title: Wire-protocol version independent of crate semver, N-1 compat window
2026-06-07T23:26:21.0518846Z - Required stages: impl, unit
2026-06-07T23:26:21.0519048Z 
2026-06-07T23:26:21.0519175Z ### REQ-ARCH-4
2026-06-07T23:26:21.0519501Z - Title: Copy-verbatim the commodity layer from the sister project
2026-06-07T23:26:21.0519892Z - Required stages: impl, unit
2026-06-07T23:26:21.0520079Z 
2026-06-07T23:26:21.0520202Z ### REQ-DAEMON-1
2026-06-07T23:26:21.0520526Z - Title: One per-machine spt-daemon owning all per-machine state
2026-06-07T23:26:21.0520918Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0521127Z 
2026-06-07T23:26:21.0521242Z ### REQ-DAEMON-2
2026-06-07T23:26:21.0521518Z - Title: Broker/brain split for seamless self-update
2026-06-07T23:26:21.0521872Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0522075Z 
2026-06-07T23:26:21.0522194Z ### REQ-DAEMON-3
2026-06-07T23:26:21.0522480Z - Title: Any api invocation auto-starts the daemon if absent
2026-06-07T23:26:21.0522828Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0523215Z 
2026-06-07T23:26:21.0523325Z ### REQ-DAEMON-4
2026-06-07T23:26:21.0523577Z - Title: Honor every KNOWN-HAZARDS invariant
2026-06-07T23:26:21.0523888Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0524078Z 
2026-06-07T23:26:21.0524198Z ### REQ-STORE-1
2026-06-07T23:26:21.0525299Z - Title: spt-store::BranchStore (git branch as versioned KV; commit=checkpoint/tip=resume, atomic multi-key, merge-native sync) is the substrate for coarse/durable/audited state (context, registry snapshot+distribution, daemon checkpoint); hot paths (B5 fsync journal) + indexed queries (SQLite spool) excluded (ADR-0011)
2026-06-07T23:26:21.0526478Z - Required stages: impl, unit
2026-06-07T23:26:21.0526664Z 
2026-06-07T23:26:21.0526788Z ### REQ-MANIFEST-1
2026-06-07T23:26:21.0527239Z - Title: Per-adapter manifest with adapter_name and min_spt_core_version
2026-06-07T23:26:21.0527657Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0527847Z 
2026-06-07T23:26:21.0527953Z ### REQ-SEAM-SPAWN
2026-06-07T23:26:21.0528195Z - Title: spawn-session seam
2026-06-07T23:26:21.0528463Z - Required stages: impl, unit
2026-06-07T23:26:21.0528649Z 
2026-06-07T23:26:21.0528768Z ### REQ-SEAM-POSTSPAWN
2026-06-07T23:26:21.0529053Z - Title: post-spawn / api bind seam with boot nonce
2026-06-07T23:26:21.0529382Z - Required stages: impl, unit
2026-06-07T23:26:21.0529560Z 
2026-06-07T23:26:21.0529688Z ### REQ-SEAM-PSYCHE
2026-06-07T23:26:21.0529963Z - Title: spawn-psyche seam (fresh + resume templates)
2026-06-07T23:26:21.0530433Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0530619Z 
2026-06-07T23:26:21.0530738Z ### REQ-SEAM-HISTORY
2026-06-07T23:26:21.0531067Z - Title: History subsystem (fetcher / locate-normalize / native store)
2026-06-07T23:26:21.0531401Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0531559Z 
2026-06-07T23:26:21.0531654Z ### REQ-SEAM-ACTIVITY
2026-06-07T23:26:21.0531921Z - Title: Activity/idle reported via api sentinels, not PTY quiescence
2026-06-07T23:26:21.0532212Z - Required stages: impl, unit
2026-06-07T23:26:21.0532365Z 
2026-06-07T23:26:21.0532466Z ### REQ-SEAM-INJECT
2026-06-07T23:26:21.0532706Z - Title: inject-input methods configurable per activity-state
2026-06-07T23:26:21.0532988Z - Required stages: impl, unit
2026-06-07T23:26:21.0533136Z 
2026-06-07T23:26:21.0533227Z ### REQ-SEAM-RESUME
2026-06-07T23:26:21.0533484Z - Title: resume-session seam (fresh-with-preload / continue-existing)
2026-06-07T23:26:21.0533808Z - Required stages: impl, unit
2026-06-07T23:26:21.0533956Z 
2026-06-07T23:26:21.0534062Z ### REQ-SEAM-CAPABILITY
2026-06-07T23:26:21.0534299Z - Title: Hostable endpoint-types capability declaration
2026-06-07T23:26:21.0534571Z - Required stages: impl, unit
2026-06-07T23:26:21.0534720Z 
2026-06-07T23:26:21.0534814Z ### REQ-SEAM-UPDATE
2026-06-07T23:26:21.0535068Z - Title: Adapter-update avenue (file-pull / delegated command)
2026-06-07T23:26:21.0535352Z - Required stages: impl, unit
2026-06-07T23:26:21.0535503Z 
2026-06-07T23:26:21.0535597Z ### REQ-API-1
2026-06-07T23:26:21.0535841Z - Title: api prefix and adapter_name on every machinery invocation
2026-06-07T23:26:21.0536127Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0536275Z 
2026-06-07T23:26:21.0536371Z ### REQ-API-2
2026-06-07T23:26:21.0536638Z - Title: The api subcommand surface (bind/listen/poll/state/worker/boundary/...)
2026-06-07T23:26:21.0537061Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0537219Z 
2026-06-07T23:26:21.0537320Z ### REQ-API-3
2026-06-07T23:26:21.0537539Z - Title: commune/signoff are file-drops, not commands
2026-06-07T23:26:21.0537799Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0537952Z 
2026-06-07T23:26:21.0538050Z ### REQ-START-1
2026-06-07T23:26:21.0538312Z - Title: Adapters never resolve SPT_HOME; binary on PATH; api bridging only
2026-06-07T23:26:21.0538627Z - Required stages: impl, unit
2026-06-07T23:26:21.0538779Z 
2026-06-07T23:26:21.0538866Z ### REQ-START-2
2026-06-07T23:26:21.0539084Z - Title: Harness-hosted startup: api seed then listen
2026-06-07T23:26:21.0539452Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0539604Z 
2026-06-07T23:26:21.0539699Z ### REQ-START-3
2026-06-07T23:26:21.0539942Z - Title: spt-hosted startup: spawn-session then api bind (no file)
2026-06-07T23:26:21.0540234Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0540389Z 
2026-06-07T23:26:21.0540481Z ### REQ-START-4
2026-06-07T23:26:21.0540693Z - Title: Adapter-injected env aliases (SPT/OWL/LIVE)
2026-06-07T23:26:21.0540955Z - Required stages: impl, unit
2026-06-07T23:26:21.0541108Z 
2026-06-07T23:26:21.0541204Z ### REQ-EP-1
2026-06-07T23:26:21.0541413Z - Title: Day-one endpoint types; open type system
2026-06-07T23:26:21.0541679Z - Required stages: impl, unit
2026-06-07T23:26:21.0541823Z 
2026-06-07T23:26:21.0541918Z ### REQ-EP-2
2026-06-07T23:26:21.0542152Z - Title: Agent endpoints vs Shells distinction in the type model
2026-06-07T23:26:21.0542430Z - Required stages: impl, unit
2026-06-07T23:26:21.0542571Z 
2026-06-07T23:26:21.0542658Z ### REQ-EP-3
2026-06-07T23:26:21.0542915Z - Title: Messaging payloads carry typed operation commands + file blobs
2026-06-07T23:26:21.0543229Z - Required stages: impl, unit
2026-06-07T23:26:21.0543372Z 
2026-06-07T23:26:21.0543467Z ### REQ-EP-4
2026-06-07T23:26:21.0543687Z - Title: PresenceChannel broker endpoint (seam day-one)
2026-06-07T23:26:21.0543953Z - Required stages: impl, unit
2026-06-07T23:26:21.0544102Z 
2026-06-07T23:26:21.0544192Z ### REQ-EP-5
2026-06-07T23:26:21.0544883Z - Title: Concrete shell instantiation model: spawn-mints-instance (vs relink/online), registered-on-node permission + broadcast-is-discovery, per-shell require_approval gate, max_instances_per_owner + over_cap, instance aliasing, discovery scope
2026-06-07T23:26:21.0545769Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0545927Z 
2026-06-07T23:26:21.0546020Z ### REQ-INST-1
2026-06-07T23:26:21.0546254Z - Title: endpoint ID vs instance split (adapter-agnostic ID)
2026-06-07T23:26:21.0546525Z - Required stages: 
2026-06-07T23:26:21.0546654Z 
2026-06-07T23:26:21.0546749Z ### REQ-INST-2
2026-06-07T23:26:21.0547026Z - Title: Per-node files, synced Psyche mind
2026-06-07T23:26:21.0547278Z - Required stages: impl, unit
2026-06-07T23:26:21.0547431Z 
2026-06-07T23:26:21.0547527Z ### REQ-INST-3
2026-06-07T23:26:21.0547750Z - Title: Dormant (warm) / suspended (cold) resting states
2026-06-07T23:26:21.0548008Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0548161Z 
2026-06-07T23:26:21.0548260Z ### REQ-INST-4
2026-06-07T23:26:21.0548507Z - Title: active to dormant/suspended fires a transition echo commune
2026-06-07T23:26:21.0548801Z - Required stages: impl, unit
2026-06-07T23:26:21.0548949Z 
2026-06-07T23:26:21.0549039Z ### REQ-INST-5
2026-06-07T23:26:21.0549287Z - Title: Two-tier context sync (live to all, project to same-project)
2026-06-07T23:26:21.0549592Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0549745Z 
2026-06-07T23:26:21.0549836Z ### REQ-INST-6
2026-06-07T23:26:21.0550094Z - Title: Deferred messages not delivered to dormant/suspended instances
2026-06-07T23:26:21.0550404Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0550560Z 
2026-06-07T23:26:21.0550646Z ### REQ-INST-7
2026-06-07T23:26:21.0550864Z - Title: Subnet registry + bare-id resolution policy
2026-06-07T23:26:21.0551130Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0551276Z 
2026-06-07T23:26:21.0551378Z ### REQ-INST-8
2026-06-07T23:26:21.0551615Z - Title: Remote-control mode distinct from local operation
2026-06-07T23:26:21.0551892Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0552050Z 
2026-06-07T23:26:21.0552140Z ### REQ-INST-9
2026-06-07T23:26:21.0552388Z - Title: Multi-subnet membership (same-user N subnets; cross-user seam)
2026-06-07T23:26:21.0552689Z - Required stages: impl, unit
2026-06-07T23:26:21.0552841Z 
2026-06-07T23:26:21.0552937Z ### REQ-INST-10
2026-06-07T23:26:21.0553218Z - Title: Qualified addressing [subnet:]id[@node] + ambiguity forces qualification
2026-06-07T23:26:21.0553553Z - Required stages: impl, unit
2026-06-07T23:26:21.0553793Z 
2026-06-07T23:26:21.0553893Z ### REQ-INST-11
2026-06-07T23:26:21.0554170Z - Title: spt rename <id> rippled to all instances (collision-checked, 6.5-reconciled)
2026-06-07T23:26:21.0554504Z - Required stages: impl, unit
2026-06-07T23:26:21.0554653Z 
2026-06-07T23:26:21.0554742Z ### REQ-INST-12
2026-06-07T23:26:21.0555100Z - Title: Endpoint visibility per-(endpoint,subnet): excluded semantics, OR-of-defaults + override, gates sync
2026-06-07T23:26:21.0555502Z - Required stages: impl, unit
2026-06-07T23:26:21.0555648Z 
2026-06-07T23:26:21.0555743Z ### REQ-INST-13
2026-06-07T23:26:21.0556001Z - Title: Subnet-exclusive sync + per-endpoint subnet-membership list
2026-06-07T23:26:21.0564630Z - Required stages: impl, unit
2026-06-07T23:26:21.0564845Z 
2026-06-07T23:26:21.0564954Z ### REQ-INST-14
2026-06-07T23:26:21.0565418Z - Title: Resource advertisement (subnet resource registry): free-text blurb, both-authored, registry projection, visibility/whitelist-gated
2026-06-07T23:26:21.0565922Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0566105Z 
2026-06-07T23:26:21.0566203Z ### REQ-INST-15
2026-06-07T23:26:21.0567061Z - Title: Immutable home subnet (assigned at creation: auto-if-one/ask-if-many) + spt fork (cross-subnet clone to a new identity, copy-then-diverge, not re-home); adapter chosen at creation from registered hostable adapters, changed only via launch/resume-under-new (ADR-0010)
2026-06-07T23:26:21.0567874Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0568036Z 
2026-06-07T23:26:21.0568342Z ### REQ-REACH-1
2026-06-07T23:26:21.0568575Z - Title: Off-node remote-drive detection + file transfer
2026-06-07T23:26:21.0568870Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0569028Z 
2026-06-07T23:26:21.0569119Z ### REQ-REACH-2
2026-06-07T23:26:21.0569352Z - Title: Remote command execution (deferred, consent-gated)
2026-06-07T23:26:21.0569632Z - Required stages: 
2026-06-07T23:26:21.0569768Z 
2026-06-07T23:26:21.0569859Z ### REQ-MSG-1
2026-06-07T23:26:21.0570346Z - Title: Local message delivery: TCP-first to a registered address, spool fallback when offline; id->address via registry (stale-clean first); reply routing (__REPLY_TO__)
2026-06-07T23:26:21.0570909Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0571065Z 
2026-06-07T23:26:21.0571157Z ### REQ-MSG-2
2026-06-07T23:26:21.0571505Z - Title: spt binary CLI surface: send/ring/ready(+--once)/list/stop/whoami, stable arg shapes + exit codes
2026-06-07T23:26:21.0571886Z - Required stages: impl, unit
2026-06-07T23:26:21.0572051Z 
2026-06-07T23:26:21.0572138Z ### REQ-MSG-3
2026-06-07T23:26:21.0572570Z - Title: Ready-agent lifecycle: register perch (info.json + listener + registry address) on ready, drain spooled backlog on startup, clean teardown
2026-06-07T23:26:21.0573055Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0573212Z 
2026-06-07T23:26:21.0573307Z ### REQ-MSG-4
2026-06-07T23:26:21.0574208Z - Title: Listener stream stdout emits EVENT envelope lines (sister-format, ADR-0001): parse the __REPLY_TO__ frame, pass pre-formed typed envelopes through verbatim (no double-wrap), compose <EVENT type="msg" from=…> otherwise, chunk oversized lines into EVENT-PART
2026-06-07T23:26:21.0575005Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0575167Z 
2026-06-07T23:26:21.0575266Z ### REQ-NODE-IDENTITY
2026-06-07T23:26:21.0575571Z - Title: Ed25519 identity primitive: keypair, detached sign/verify, stable pubkey<->hex
2026-06-07T23:26:21.0575924Z - Required stages: impl, unit
2026-06-07T23:26:21.0576077Z 
2026-06-07T23:26:21.0576181Z ### REQ-NET-1
2026-06-07T23:26:21.0576425Z - Title: WAN messaging first-class, behind default-on net feature flag
2026-06-07T23:26:21.0576735Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0576888Z 
2026-06-07T23:26:21.0577068Z ### REQ-NET-2
2026-06-07T23:26:21.0577327Z - Title: n0 relay default + self-host knob + plain-language disclosure
2026-06-07T23:26:21.0577616Z - Required stages: impl
2026-06-07T23:26:21.0577752Z 
2026-06-07T23:26:21.0577847Z ### REQ-NET-3
2026-06-07T23:26:21.0578215Z - Title: Cross-node Psyche sync over P2P replaces gh-repo-sync
2026-06-07T23:26:21.0578511Z - Required stages: impl, unit
2026-06-07T23:26:21.0578653Z 
2026-06-07T23:26:21.0578753Z ### REQ-PAIR-1
2026-06-07T23:26:21.0578944Z - Title: TOTP-seeded SPAKE2 pairing
2026-06-07T23:26:21.0579174Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0579331Z 
2026-06-07T23:26:21.0579421Z ### REQ-PAIR-2
2026-06-07T23:26:21.0579645Z - Title: Local trust store with TOFU + warn-on-change
2026-06-07T23:26:21.0579921Z - Required stages: impl, unit
2026-06-07T23:26:21.0580063Z 
2026-06-07T23:26:21.0580159Z ### REQ-PAIR-3
2026-06-07T23:26:21.0580375Z - Title: Fetch current pairing code from any paired node
2026-06-07T23:26:21.0580648Z - Required stages: impl, unit
2026-06-07T23:26:21.0580797Z 
2026-06-07T23:26:21.0580887Z ### REQ-PAIR-4
2026-06-07T23:26:21.0581077Z - Title: Subnet naming on first pairing
2026-06-07T23:26:21.0581315Z - Required stages: impl, unit
2026-06-07T23:26:21.0581459Z 
2026-06-07T23:26:21.0581564Z ### REQ-PAIR-5
2026-06-07T23:26:21.0581935Z - Title: Multi-subnet pairing: subnet-name discovery input, create-new-names-up-front, rendezvous-token hashing
2026-06-07T23:26:21.0582346Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0582502Z 
2026-06-07T23:26:21.0582597Z ### REQ-PAIR-6
2026-06-07T23:26:21.0582918Z - Title: Elevation-gated per-subnet code fetch (UAC/root or elevated agent; else authenticator app)
2026-06-07T23:26:21.0583300Z - Required stages: impl, unit
2026-06-07T23:26:21.0583552Z 
2026-06-07T23:26:21.0583644Z ### REQ-PAIR-7
2026-06-07T23:26:21.0583886Z - Title: Subnet icon (inline image metadata, GUI-only consumer)
2026-06-07T23:26:21.0584168Z - Required stages: 
2026-06-07T23:26:21.0584289Z 
2026-06-07T23:26:21.0584383Z ### REQ-SUBNET-1
2026-06-07T23:26:21.0584768Z - Title: spt subnet noun namespace: status view (bare + status [NAME] [--nodes]), create (QR/otpauth), show-code; spt pair deleted
2026-06-07T23:26:21.0585199Z - Required stages: impl, unit
2026-06-07T23:26:21.0585356Z 
2026-06-07T23:26:21.0585440Z ### REQ-SUBNET-2
2026-06-07T23:26:21.0585732Z - Title: Guided join e2e: spt subnet join CLI initiator + always-on daemon pairing responder
2026-06-07T23:26:21.0586093Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0586252Z 
2026-06-07T23:26:21.0586343Z ### REQ-SUBNET-3
2026-06-07T23:26:21.0586690Z - Title: Node labels: hostname-default, gossiped, addressable in @node qualifiers (refuse-on-ambiguity)
2026-06-07T23:26:21.0587138Z - Required stages: impl, unit
2026-06-07T23:26:21.0587309Z 
2026-06-07T23:26:21.0587410Z ### REQ-SUBNET-4
2026-06-07T23:26:21.0587763Z - Title: Subnet membership mutations elevation-gated (create = seed reveal; join = trust-boundary enrollment)
2026-06-07T23:26:21.0588172Z - Required stages: impl, unit
2026-06-07T23:26:21.0588317Z 
2026-06-07T23:26:21.0588412Z ### REQ-DOCS-6
2026-06-07T23:26:21.0588790Z - Title: spt how-to <topic>: in-binary task-oriented agent instructions (anti-drift; quickstart prompts point agents at it)
2026-06-07T23:26:21.0589233Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0589395Z 
2026-06-07T23:26:21.0589486Z ### REQ-SEC-1
2026-06-07T23:26:21.0589928Z - Title: Per-endpoint access whitelist: origin-node gate, stateful-firewall (reply/outbound exempt), node-now/user-later, outer gate before grants
2026-06-07T23:26:21.0590426Z - Required stages: impl, unit
2026-06-07T23:26:21.0590576Z 
2026-06-07T23:26:21.0590671Z ### REQ-NOTIF-1
2026-06-07T23:26:21.0591090Z - Title: Notification primitive: per-subnet replicated spool, seen/dismissed, resurface-at-boundary, subsumes update+consent prompts
2026-06-07T23:26:21.0591561Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0591752Z 
2026-06-07T23:26:21.0591851Z ### REQ-NOTIF-2
2026-06-07T23:26:21.0592176Z - Title: spt notify (agent-issued subnet notif) + notif_command manifest seam (harness + shell adapters)
2026-06-07T23:26:21.0592557Z - Required stages: doc, impl, unit, int
2026-06-07T23:26:21.0592743Z 
2026-06-07T23:26:21.0592839Z ### REQ-UPD-1
2026-06-07T23:26:21.0593138Z - Title: Peer-propagated update over P2P
2026-06-07T23:26:21.0593379Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0593536Z 
2026-06-07T23:26:21.0593628Z ### REQ-UPD-2
2026-06-07T23:26:21.0593846Z - Title: All binaries signature-verified before handoff
2026-06-07T23:26:21.0594117Z - Required stages: impl, unit
2026-06-07T23:26:21.0594266Z 
2026-06-07T23:26:21.0594357Z ### REQ-UPD-3
2026-06-07T23:26:21.0594605Z - Title: No endpoint process terminates/suspends during self-update
2026-06-07T23:26:21.0594910Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0595062Z 
2026-06-07T23:26:21.0595154Z ### REQ-UPD-4
2026-06-07T23:26:21.0595410Z - Title: Update gated on user confirmation by default; opt-in full-auto
2026-06-07T23:26:21.0595720Z - Required stages: impl, unit
2026-06-07T23:26:21.0595869Z 
2026-06-07T23:26:21.0595958Z ### REQ-UPD-5
2026-06-07T23:26:21.0596173Z - Title: spt-core ripple-updates registered adapters
2026-06-07T23:26:21.0596444Z - Required stages: impl, unit
2026-06-07T23:26:21.0596597Z 
2026-06-07T23:26:21.0596686Z ### REQ-UPD-6
2026-06-07T23:26:21.0597612Z - Title: Platform-targeted update sets and debug rollout: signed multi-platform update metadata, recipient platform selection, channel-scoped monotonic counters, debug-channel opt-in via release-key overlay, local staging plus pull-based peer propagation, and maintainer-only convergence tooling (ADR-0016)
2026-06-07T23:26:21.0598499Z - Required stages: doc, impl, unit, int
2026-06-07T23:26:21.0598675Z 
2026-06-07T23:26:21.0598867Z ### REQ-TERM-1
2026-06-07T23:26:21.0599116Z - Title: Process-supervisor terminal wrapper hosting broker PTYs
2026-06-07T23:26:21.0599416Z - Required stages: impl, unit
2026-06-07T23:26:21.0599568Z 
2026-06-07T23:26:21.0599660Z ### REQ-TERM-2
2026-06-07T23:26:21.0599912Z - Title: session-surface abstraction; send-keys + send-line injection
2026-06-07T23:26:21.0600212Z - Required stages: impl, unit
2026-06-07T23:26:21.0600356Z 
2026-06-07T23:26:21.0600446Z ### REQ-TERM-3
2026-06-07T23:26:21.0600667Z - Title: Byte-stream remote terminal streaming for v1
2026-06-07T23:26:21.0600924Z - Required stages: impl, unit
2026-06-07T23:26:21.0601070Z 
2026-06-07T23:26:21.0601165Z ### REQ-TERM-4
2026-06-07T23:26:21.0601568Z - Title: Live activity buffer (PTY digest): adapter-supplied patterns over broker PTY, spt digest pull + delta-stream, opt-in Path-B log
2026-06-07T23:26:21.0602031Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0602188Z 
2026-06-07T23:26:21.0602279Z ### REQ-FRONT-1
2026-06-07T23:26:21.0602532Z - Title: Day-one launcher/manager frontend (list/launch/attach/init)
2026-06-07T23:26:21.0602823Z - Required stages: 
2026-06-07T23:26:21.0602950Z 
2026-06-07T23:26:21.0603041Z ### REQ-INSTALL-1
2026-06-07T23:26:21.0603317Z - Title: Two install paths; signed one-line script; OS-service registration
2026-06-07T23:26:21.0603636Z - Required stages: doc, impl, int
2026-06-07T23:26:21.0603779Z 
2026-06-07T23:26:21.0603865Z ### REQ-INSTALL-2
2026-06-07T23:26:21.0604077Z - Title: Marketplace-repackaging-friendly install
2026-06-07T23:26:21.0604354Z - Required stages: doc
2026-06-07T23:26:21.0604493Z 
2026-06-07T23:26:21.0604583Z ### REQ-INSTALL-3
2026-06-07T23:26:21.0604798Z - Title: Idempotent + interactive-optional first run
2026-06-07T23:26:21.0605069Z - Required stages: impl, int
2026-06-07T23:26:21.0605212Z 
2026-06-07T23:26:21.0605307Z ### REQ-INSTALL-4
2026-06-07T23:26:21.0605965Z - Title: Adapter registration lifecycle: spt adapter add (--github, manifest-first, install-is-first-update) + soft-deregister remove + optional manifest uninstall template; node-local registered-adapter set self-update ripples over
2026-06-07T23:26:21.0606675Z - Required stages: impl, unit
2026-06-07T23:26:21.0606828Z 
2026-06-07T23:26:21.0606922Z ### REQ-MIGRATE-1
2026-06-07T23:26:21.0607256Z - Title: Auto-detect and migrate a legacy claude_skill_owl install
2026-06-07T23:26:21.0607542Z - Required stages: 
2026-06-07T23:26:21.0607668Z 
2026-06-07T23:26:21.0607762Z ### REQ-INFRA-1
2026-06-07T23:26:21.0608011Z - Title: GitHub issue tracking for v1; tangled.org as migration target
2026-06-07T23:26:21.0608411Z - Required stages: 
2026-06-07T23:26:21.0608539Z 
2026-06-07T23:26:21.0608631Z ### REQ-INSTALL-5
2026-06-07T23:26:21.0609158Z - Title: Non-interactive install path: the canonical one-liner doubles as every adapter's pack-in on-demand install (no second mechanism); sha256-verified fetch; user-PATH registration
2026-06-07T23:26:21.0609724Z - Required stages: impl, int
2026-06-07T23:26:21.0609876Z 
2026-06-07T23:26:21.0609972Z ### REQ-REL-1
2026-06-07T23:26:21.0610410Z - Title: spt-releases publish-target repo: README public face, licensing split, Pages docs at the permanent lapse-proof canonical URL (ADR-0014)
2026-06-07T23:26:21.0610898Z - Required stages: doc, impl
2026-06-07T23:26:21.0611039Z 
2026-06-07T23:26:21.0611130Z ### REQ-REL-2
2026-06-07T23:26:21.0611649Z - Title: Release asset set consumable by the self-updater: platform binaries, SHA256SUMS, SignedRelease metadata, manifest schema, mock-adapter zip; tag-triggered cross-repo pipeline
2026-06-07T23:26:21.0612233Z - Required stages: impl, int
2026-06-07T23:26:21.0612380Z 
2026-06-07T23:26:21.0612477Z ### REQ-REL-3
2026-06-07T23:26:21.0612952Z - Title: Two-key release-signing trust anchor: primary + offline never-used recovery, both pubkeys embedded in the binary's trusted set, manual local signing (ADR-0015)
2026-06-07T23:26:21.0613492Z - Required stages: impl, unit
2026-06-07T23:26:21.0613644Z 
2026-06-07T23:26:21.0613731Z ### REQ-DOCS-1
2026-06-07T23:26:21.0614201Z - Title: Dual-audience docs (human + AI dev-agent), markdown once / two depths
2026-06-07T23:26:21.0614518Z - Required stages: doc, impl
2026-06-07T23:26:21.0614666Z 
2026-06-07T23:26:21.0614762Z ### REQ-DOCS-2
2026-06-07T23:26:21.0614995Z - Title: Sub-10-minute runnable killer quickstart per audience
2026-06-07T23:26:21.0615291Z - Required stages: doc, int
2026-06-07T23:26:21.0615429Z 
2026-06-07T23:26:21.0615514Z ### REQ-DOCS-3
2026-06-07T23:26:21.0615806Z - Title: Diátaxis structure; one canonical way to do X
2026-06-07T23:26:21.0616082Z - Required stages: doc
2026-06-07T23:26:21.0616202Z 
2026-06-07T23:26:21.0616293Z ### REQ-DOCS-4
2026-06-07T23:26:21.0616559Z - Title: Agent-consumable layer (llms.txt, manifest schema, MCP, CLI help)
2026-06-07T23:26:21.0616894Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0617139Z 
2026-06-07T23:26:21.0617230Z ### REQ-DOCS-5
2026-06-07T23:26:21.0617496Z - Title: Anti-drift: rustdoc/schema/exports/CLI-help generated + CI-checked
2026-06-07T23:26:21.0617821Z - Required stages: impl, int
2026-06-07T23:26:21.0617970Z 
2026-06-07T23:26:21.0618084Z ### REQ-HAZARD-GRACE-BEFORE-SIGNOFF
2026-06-07T23:26:21.0618398Z - Title: Grace-period wait completes before composing INIT_SIGNOFF (1.1)
2026-06-07T23:26:21.0618723Z - Required stages: impl, unit
2026-06-07T23:26:21.0618876Z 
2026-06-07T23:26:21.0618985Z ### REQ-HAZARD-INFO-JSON-TORN-READ
2026-06-07T23:26:21.0619258Z - Title: State-file reads tolerate concurrent writes (1.2)
2026-06-07T23:26:21.0619577Z - Required stages: impl, unit
2026-06-07T23:26:21.0619732Z 
2026-06-07T23:26:21.0619837Z ### REQ-HAZARD-STALE-INDEX-LOCK
2026-06-07T23:26:21.0620102Z - Title: Sweep stale lockfiles on daemon boot (1.3)
2026-06-07T23:26:21.0620359Z - Required stages: impl, unit
2026-06-07T23:26:21.0620503Z 
2026-06-07T23:26:21.0620613Z ### REQ-HAZARD-DEFERRED-DRAIN
2026-06-07T23:26:21.0620898Z - Title: Deferred spool rows excluded from the event-stream drain (1.4)
2026-06-07T23:26:21.0621208Z - Required stages: impl, unit
2026-06-07T23:26:21.0621357Z 
2026-06-07T23:26:21.0621467Z ### REQ-HAZARD-WORKER-PATH
2026-06-07T23:26:21.0621748Z - Title: Single source of truth for Worker/Psyche perch location (1.5)
2026-06-07T23:26:21.0622049Z - Required stages: impl, unit
2026-06-07T23:26:21.0622195Z 
2026-06-07T23:26:21.0622308Z ### REQ-HAZARD-PARENT-PID-PREFER
2026-06-07T23:26:21.0622616Z - Title: Prefer stable parent PID / broker handle over ephemeral PID (2.1)
2026-06-07T23:26:21.0622926Z - Required stages: 
2026-06-07T23:26:21.0623052Z 
2026-06-07T23:26:21.0623260Z ### REQ-HAZARD-STDIN-SESSION-ID
2026-06-07T23:26:21.0623522Z - Title: Stdin session_id precedence over env (2.2)
2026-06-07T23:26:21.0623780Z - Required stages: 
2026-06-07T23:26:21.0623909Z 
2026-06-07T23:26:21.0624015Z ### REQ-HAZARD-HANDOFF-ARGV-COMPAT
2026-06-07T23:26:21.0624291Z - Title: Broker/brain IPC + handoff argv version-tolerant (2.3)
2026-06-07T23:26:21.0624587Z - Required stages: impl, unit
2026-06-07T23:26:21.0624733Z 
2026-06-07T23:26:21.0624842Z ### REQ-HAZARD-GEN-START-NOW
2026-06-07T23:26:21.0625352Z - Title: gen_start = now() on cold-start and handoff (2.4)
2026-06-07T23:26:21.0625627Z - Required stages: impl, int
2026-06-07T23:26:21.0625774Z 
2026-06-07T23:26:21.0625884Z ### REQ-HAZARD-EPHEMERAL-CLEANUP
2026-06-07T23:26:21.0626151Z - Title: Ephemeral perch cleanup on every ring exit path (3.1)
2026-06-07T23:26:21.0626432Z - Required stages: impl, unit
2026-06-07T23:26:21.0626591Z 
2026-06-07T23:26:21.0626704Z ### REQ-HAZARD-STALE-SIGNOFF-SENTINEL
2026-06-07T23:26:21.0627091Z - Title: Stale signoff sentinel does not kill a fresh start (3.2)
2026-06-07T23:26:21.0627376Z - Required stages: impl, unit
2026-06-07T23:26:21.0627517Z 
2026-06-07T23:26:21.0627633Z ### REQ-HAZARD-ECHO-BEFORE-SIGNOFF
2026-06-07T23:26:21.0627934Z - Title: Echo-commune fires before INIT_SIGNOFF on orphan teardown (3.3)
2026-06-07T23:26:21.0628244Z - Required stages: impl, unit
2026-06-07T23:26:21.0628396Z 
2026-06-07T23:26:21.0628506Z ### REQ-HAZARD-ENVELOPE-DECODE-ORDER
2026-06-07T23:26:21.0628978Z - Title: Envelope decode order, ampersand decoded last (4.1)
2026-06-07T23:26:21.0629259Z - Required stages: impl, unit
2026-06-07T23:26:21.0629403Z 
2026-06-07T23:26:21.0629517Z ### REQ-HAZARD-ENVELOPE-PARSER-SAFE
2026-06-07T23:26:21.0629808Z - Title: Two-slice envelope parser is panic-free and tolerant (4.2)
2026-06-07T23:26:21.0630113Z - Required stages: impl, unit
2026-06-07T23:26:21.0630259Z 
2026-06-07T23:26:21.0630369Z ### REQ-HAZARD-EVENTPART-REASSEMBLY
2026-06-07T23:26:21.0630696Z - Title: EVENT-PART split/reassembly is byte-exact; orphan parts dropped silently
2026-06-07T23:26:21.0631035Z - Required stages: impl, unit
2026-06-07T23:26:21.0631178Z 
2026-06-07T23:26:21.0631287Z ### REQ-HAZARD-ID-CHARSET
2026-06-07T23:26:21.0631621Z - Title: Addressable-id charset reserves :/@ delimiters; validated at every creation seam (4.6)
2026-06-07T23:26:21.0631989Z - Required stages: impl, unit
2026-06-07T23:26:21.0632136Z 
2026-06-07T23:26:21.0632246Z ### REQ-HAZARD-REGISTRY-STALE-CLEAN
2026-06-07T23:26:21.0632546Z - Title: Stale registry entries degrade to fallback, never hard-fail (4.3)
2026-06-07T23:26:21.0632864Z - Required stages: impl, unit
2026-06-07T23:26:21.0633012Z 
2026-06-07T23:26:21.0633128Z ### REQ-HAZARD-REGISTRY-CONCURRENT
2026-06-07T23:26:21.0633477Z - Title: Concurrent SQLite openers (registry/spool) must not fail with 'database is locked' (4.7)
2026-06-07T23:26:21.0633839Z - Required stages: impl, unit
2026-06-07T23:26:21.0633992Z 
2026-06-07T23:26:21.0634096Z ### REQ-HAZARD-REGISTRY-DIR-CREATE
2026-06-07T23:26:21.0634589Z - Title: SQLite store opens create their parent dir themselves — a fresh-home registry op must not SQLITE_CANTOPEN (4.9)
2026-06-07T23:26:21.0635032Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0635175Z 
2026-06-07T23:26:21.0635294Z ### REQ-HAZARD-REGISTRY-EPOCH-LEASE
2026-06-07T23:26:21.0635827Z - Title: Registry merge ordered by per-node monotonic epoch, never wall-clock — a stale Active can't clobber a newer Offline (4.8, red-team #8)
2026-06-07T23:26:21.0636313Z - Required stages: impl, unit
2026-06-07T23:26:21.0636467Z 
2026-06-07T23:26:21.0636586Z ### REQ-HAZARD-DEFERRED-SURVIVE-DRAIN
2026-06-07T23:26:21.0636843Z - Title: Deferred rows survive poll drain (4.4)
2026-06-07T23:26:21.0637200Z - Required stages: impl, unit
2026-06-07T23:26:21.0637352Z 
2026-06-07T23:26:21.0637459Z ### REQ-HAZARD-INBOX-NO-DOUBLE
2026-06-07T23:26:21.0637702Z - Title: No double-delivery via legacy inbox (4.5)
2026-06-07T23:26:21.0637958Z - Required stages: impl, unit
2026-06-07T23:26:21.0638205Z 
2026-06-07T23:26:21.0638319Z ### REQ-HAZARD-WINDOWS-PID-RECYCLE
2026-06-07T23:26:21.0638589Z - Title: Windows PID-recycling false positives guarded (5.1)
2026-06-07T23:26:21.0638865Z - Required stages: impl, unit
2026-06-07T23:26:21.0639038Z 
2026-06-07T23:26:21.0639143Z ### REQ-HAZARD-EBUSY-RENAME
2026-06-07T23:26:21.0639414Z - Title: tmp-write + atomic-rename + retry on Windows EBUSY (5.2)
2026-06-07T23:26:21.0639701Z - Required stages: impl, unit
2026-06-07T23:26:21.0639843Z 
2026-06-07T23:26:21.0639963Z ### REQ-HAZARD-SUBPROCESS-TIMEOUT
2026-06-07T23:26:21.0640229Z - Title: Every harness/git subprocess has a timeout (5.3)
2026-06-07T23:26:21.0640501Z - Required stages: impl, unit
2026-06-07T23:26:21.0640646Z 
2026-06-07T23:26:21.0640748Z ### REQ-HAZARD-UNC-PATH-STRIP
2026-06-07T23:26:21.0641005Z - Title: Strip Windows UNC prefix on serialized paths (5.4)
2026-06-07T23:26:21.0641280Z - Required stages: impl, unit
2026-06-07T23:26:21.0641427Z 
2026-06-07T23:26:21.0641537Z ### REQ-HAZARD-SINGLE-PATH-SOURCE
2026-06-07T23:26:21.0641842Z - Title: Single path/registry source of truth; no layout ambiguity (6.1)
2026-06-07T23:26:21.0642147Z - Required stages: impl, unit
2026-06-07T23:26:21.0642291Z 
2026-06-07T23:26:21.0642400Z ### REQ-HAZARD-SOFT-CLEANUP
2026-06-07T23:26:21.0642691Z - Title: Soft-cleanup preserves state, removes only the ready marker (6.2)
2026-06-07T23:26:21.0643015Z - Required stages: impl, unit
2026-06-07T23:26:21.0643160Z 
2026-06-07T23:26:21.0643282Z ### REQ-HAZARD-CASCADE-WIPE-GUARD
2026-06-07T23:26:21.0643675Z - Title: No hard-delete of a parent hosting non-empty children (6.3)
2026-06-07T23:26:21.0643975Z - Required stages: impl, unit
2026-06-07T23:26:21.0644114Z 
2026-06-07T23:26:21.0644237Z ### REQ-HAZARD-DROP-FILE-SINGLE-WRITER
2026-06-07T23:26:21.0644524Z - Title: Drop files are daemon-owned single-writer (6.4)
2026-06-07T23:26:21.0644801Z - Required stages: impl, unit
2026-06-07T23:26:21.0644953Z 
2026-06-07T23:26:21.0645063Z ### REQ-HAZARD-DIRECT-WRITE-PRECEDENCE
2026-06-07T23:26:21.0645402Z - Title: Direct-write precedence marker (with node id) guards stale overwrite (6.5)
2026-06-07T23:26:21.0645740Z - Required stages: impl, unit
2026-06-07T23:26:21.0645886Z 
2026-06-07T23:26:21.0646000Z ### REQ-HAZARD-CONFLICT-BOTH-PRESERVED
2026-06-07T23:26:21.0646646Z - Title: A surfaced concurrent context pair is durably preserved (both versions, tracked artifacts) until a strictly dominating write clears it; no reconcile failure path discards an unmerged version (6.6, ADR-0013)
2026-06-07T23:26:21.0647382Z - Required stages: impl, unit
2026-06-07T23:26:21.0647528Z 
2026-06-07T23:26:21.0647639Z ### REQ-HAZARD-DETACHED-PIPE-INHERIT
2026-06-07T23:26:21.0648862Z - Title: Windows detached long-lived children must not inherit a captured caller's pipe: every detach-spawn of an immortal child (daemon, shell binary) runs bInheritHandles=FALSE, or a caller capturing output anywhere up the process chain hangs forever on a pipe that never EOFs — std-handle flag stripping is NOT sufficient (grandparent strays still flow) (5.6)
2026-06-07T23:26:21.0649860Z - Required stages: impl, unit
2026-06-07T23:26:21.0650007Z 
2026-06-07T23:26:21.0650117Z ### REQ-HAZARD-CONPTY-DSR
2026-06-07T23:26:21.0650432Z - Title: ConPTY reader must auto-answer DSR (ESC[6n) or all child output stalls (5.5)
2026-06-07T23:26:21.0650770Z - Required stages: impl, unit
2026-06-07T23:26:21.0650919Z 
2026-06-07T23:26:21.0651027Z ### REQ-HAZARD-CHILD-CONSOLE-FLASH
2026-06-07T23:26:21.0651560Z - Title: Console-subsystem children of the console-less daemon spawn with CREATE_NO_WINDOW, or each spawn flashes a visible blank window on the user's desktop (5.8)
2026-06-07T23:26:21.0652093Z - Required stages: impl, unit
2026-06-07T23:26:21.0652231Z 
2026-06-07T23:26:21.0652340Z ### REQ-HAZARD-INSTANT-UNDERFLOW
2026-06-07T23:26:21.0652989Z - Title: Scheduling never subtracts a Duration from Instant::now() (underflow-panics on a host booted more recently than the offset); 'due now / never run' is Option<Instant>=None gated on forward duration_since only (5.9)
2026-06-07T23:26:21.0653753Z - Required stages: impl, unit
2026-06-07T23:26:21.0653899Z 
2026-06-07T23:26:21.0654008Z ### REQ-HAZARD-SUDO-SECURE-PATH
2026-06-07T23:26:21.0654950Z - Title: Elevation guidance on Unix names the binary's ABSOLUTE path under sudo (a user-local install ~/.local/bin · ~/.cargo/bin is not on sudo's secure_path, so bare `sudo spt` dies 'command not found'); gated commands auto-elevate on an interactive TTY, else print the runnable hint (5.10)
2026-06-07T23:26:21.0655747Z - Required stages: impl, unit
2026-06-07T23:26:21.0656132Z 
2026-06-07T23:26:21.0656228Z ### REQ-HAZARD-LOCAL-API-AUTH
2026-06-07T23:26:21.0656556Z - Title: Every local `api` mutation authenticated to an endpoint/session (codex #13)
2026-06-07T23:26:21.0656887Z - Required stages: impl, unit
2026-06-07T23:26:21.0657121Z 
2026-06-07T23:26:21.0657226Z ### REQ-HAZARD-RESTART-IDEMPOTENT
2026-06-07T23:26:21.0657589Z - Title: Idempotent/exactly-once delivery across brain restart at every broker boundary (codex #14)
2026-06-07T23:26:21.0657980Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0658146Z 
2026-06-07T23:26:21.0658252Z ### REQ-HAZARD-UPDATE-ROLLBACK
2026-06-07T23:26:21.0658605Z - Title: Self-update rejects version rollback; metadata expiry + adapter content signing (codex #5)
2026-06-07T23:26:21.0658985Z - Required stages: impl, unit
2026-06-07T23:26:21.0659134Z 
2026-06-07T23:26:21.0659249Z ### REQ-HAZARD-DAEMON-HOSTED-LIVENESS
2026-06-07T23:26:21.0659766Z - Title: Daemon-hosted perches (Psyche, spt-hosted Self) derive liveness from the daemon endpoint table + info.json status, never is_process_alive(info.pid) (2.5)
2026-06-07T23:26:21.0660410Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0660567Z 
2026-06-07T23:26:21.0660686Z ### REQ-HAZARD-PSYCHE-OUTBOUND-PROXY
2026-06-07T23:26:21.0661578Z - Title: Psyche outbound captured + sanitized: the live-Psyche turn driver captures stdout (never Stdio::null), and the daemon strips/re-stamps Psyche-supplied from=/target and constrains routing (reply→__REPLY_TO__ sender, notify→own user/subnet) (7.3)
2026-06-07T23:26:21.0662333Z - Required stages: impl, unit
2026-06-07T23:26:21.0662486Z 
2026-06-07T23:26:21.0662605Z ### REQ-HAZARD-DAEMON-SCHED-NONBLOCKING
2026-06-07T23:26:21.0663336Z - Title: Per-agent pulse/psyche/echo-commune scheduling must not serialize across agents: each agent's bounded LLM call (echo-commune summarizer, Psyche turn) runs off the shared scheduler so one slow/hung call cannot stall another agent's tick (7.4)
2026-06-07T23:26:21.0664064Z - Required stages: impl, unit
2026-06-07T23:26:21.0664221Z 
2026-06-07T23:26:21.0664328Z ### REQ-HAZARD-PAIR-TRANSCRIPT-BIND
2026-06-07T23:26:21.0665076Z - Title: Pairing transcript binds roles, both node pubkeys, subnet ID, seed epoch, TOTP time-step, and confirmation MACs — or unknown-key-share/reflection/wrong-subnet/replay pairing remain possible (ADR-0005 #12)
2026-06-07T23:26:21.0665926Z - Required stages: impl, unit
2026-06-07T23:26:21.0666068Z 
2026-06-07T23:26:21.0666173Z ### REQ-HAZARD-PAIR-SEED-ROTATION
2026-06-07T23:26:21.0666798Z - Title: Removing a node rotates the subnet seed (epoch bump) so an old node/old seed cannot rejoin; trust-store delete alone is NOT revocation because the seed is replicated to every trusted node (ADR-0005 #10)
2026-06-07T23:26:21.0667510Z - Required stages: impl, unit
2026-06-07T23:26:21.0667662Z 
2026-06-07T23:26:21.0667767Z ### REQ-HAZARD-PAIR-RATE-LIMIT
2026-06-07T23:26:21.0668711Z - Title: Subnet-global pairing rate limit: one active ceremony per subnet, shared attempt counter, exponential backoff — a public pre-trust relay + multiple seed-holders otherwise enables distributed SPAKE2 guessing (and ±1 TOTP window triples the valid-password space) (ADR-0005 #11)
2026-06-07T23:26:21.0669545Z - Required stages: impl, unit
2026-06-07T23:26:21.0669689Z 
2026-06-07T23:26:21.0669799Z ### REQ-HAZARD-WAN-ORIGIN-AUTH
2026-06-07T23:26:21.0670650Z - Title: WAN-inbound origin is transport truth, never payload: the access gate's subject (ADR-0009 origin-node whitelist) is the QUIC handshake-proven remote node id from the broker's conn/stream table — a forged origin/node field inside record bytes is inert (7.5)
2026-06-07T23:26:21.0671523Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0671687Z 
2026-06-07T23:26:21.0671780Z ### REQ-CONSENT-1
2026-06-07T23:26:21.0672699Z - Title: Consent grant store: capability x subject-agent x target-node rows, enforced at the target node, subnet-settable (replicates as security material near the trust store), revocable; gated-capability ids (remote-exec, instantiate-anywhere) reserved-but-refusing; v1 consumers are the shell spawn gates (CONTEXT Consent & security gates)
2026-06-07T23:26:21.0673656Z - Required stages: impl, unit
2026-06-07T23:26:21.0673809Z 
2026-06-07T23:26:21.0673905Z ### REQ-CONSENT-2
2026-06-07T23:26:21.0674753Z - Title: Interactive consent escalation: an ungated high-risk action routes a consent prompt to the user's most-recently-active session; allow-once / allow-always (writes a grant) / deny; pre-consent flags (can_shutdown, shell_wake_spawn_anywhere) author grants via manifest/settings (CONTEXT Consent & security gates)
2026-06-07T23:26:21.0675655Z - Required stages: impl, unit
2026-06-07T23:26:21.0675803Z 
2026-06-07T23:26:21.0675899Z ### REQ-PRES-1
2026-06-07T23:26:21.0677402Z - Title: Presence resolution: the presence datum (last_active_node, last_active_endpoint, ts) gossiped subnet-wide via the agent-interaction heartbeat (rides registry distribution, visibility-gated) + one first-class most-recently-active resolution API consumed by notif first-fire, update-consent delivery, consent escalation, and shell wake resolution (M5 scope decision 1: resolution only — the PresenceChannel endpoint stays deferred)
2026-06-07T23:26:21.0678757Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0678918Z 
2026-06-07T23:26:21.0679010Z ### REQ-SHELL-1
2026-06-07T23:26:21.0679905Z - Title: Shell hosting machinery: shell perch under the owner (type/owner/adapter_name/status/alias), broker-launched binary + api bind local-link handshake, the three channels (command durable, text+file durable + progress-queryable, sensory REST-only never spooled + dropped-unless-owner-live), owner exclusivity (CONTEXT Shell model)
2026-06-07T23:26:21.0680862Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0681020Z 
2026-06-07T23:26:21.0681115Z ### REQ-SHELL-2
2026-06-07T23:26:21.0682595Z - Title: Shell sleep/wake: link-break always closes the binary (pre-close instruction + termination timeout), ephemeral teardown vs persistent offline/relink, wake_command wake-watcher (offline-only, exit-opcode supervision, exponential backoff + give-up), state-keyed wake resolution (dormant/suspended/active-elsewhere; no-reachable refuses — spawn-anywhere branch deferred), spt shutdown owner cascade + api owner-shutdown gated by can_shutdown (CONTEXT Shell sleep/wake)
2026-06-07T23:26:21.0683936Z - Required stages: impl, unit, int
2026-06-07T23:26:21.0684092Z 
2026-06-07T23:26:21.0684202Z ### REQ-HAZARD-ELEVATED-DAEMON-SPAWN
2026-06-07T23:26:21.0685532Z - Title: The daemon always runs unelevated in the invoking user's universe, regardless of which command spawns it: an elevated spawner de-elevates (Windows: UAC linked token via CreateProcessWithTokenW; Linux: drop to SUDO_UID/SUDO_GID + the invoker's HOME) — an elevated daemon's pipes deny unelevated clients (every later spt reads not-running→spawn→bind Access-denied) and a sudo'd daemon roots the user's state universe (5.7)
2026-06-07T23:26:21.0686688Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0686854Z 
2026-06-07T23:26:21.0687037Z ### REQ-HAZARD-REGISTRY-GHOST-ROWS
2026-06-07T23:26:21.0688420Z - Title: A dead node identity's registry rows must decay: only the per-(endpoint,node) epoch lease supersedes rows, so without eviction a vanished node's rows are immortal and poison bare-id resolution with phantom AcrossNodes ambiguity — evict rows whose author node has not been heard (admitted inbound feed) within the eviction window; own rows never decay; a revived node re-inserts from its durable epoch within one pump cadence (4.10)
2026-06-07T23:26:21.0689698Z - Required stages: doc, impl, unit
2026-06-07T23:26:21.0689851Z 
2026-06-07T23:26:21.0689942Z ### REQ-CLI-1
2026-06-07T23:26:21.0693615Z - Title: spt endpoint noun namespace: absorbs fork/suspend/wake/shutdown/rename/stop/digest + access (ported 1:1: allow|revoke|open|list, decision 21) + description (ex-resources blurb; bare=show, set=author); merged endpoint list [--local|--subnet <name>] grouped by subnet with SELF pinned, --detail adding the ex-resources yellow-pages blurb projection; bare spt endpoint = the list (M8 decisions 1-2, 25)
2026-06-07T23:26:21.0694853Z - Required stages: impl, unit
2026-06-07T23:26:21.0695011Z 
2026-06-07T23:26:21.0695110Z ### REQ-CLI-2
2026-06-07T23:26:21.0696154Z - Title: spt daemon noun: run|stop|status (hidden daemon verb becomes daemon run; agent-endpoint shutdown keeps its name under endpoint); daemon status renders the pump heartbeat (last-tick recency) so a half-dead daemon is never rendered implied-healthy (M8 decisions 5, 23)
2026-06-07T23:26:21.0697086Z - Required stages: impl, unit
2026-06-07T23:26:21.0697243Z 
2026-06-07T23:26:21.0697334Z ### REQ-CLI-3
2026-06-07T23:26:21.0698092Z - Title: Agent hot path stays flat across the M8 reorg: send/ring/ready/whoami/how-to unchanged; notify moves to subnet notify while notif stays top-level; breaking renames land clean with no deprecation shims (zero external CLI consumers pre-spt-claude-code) (M8 decisions 3-4, 9)
2026-06-07T23:26:21.0698892Z - Required stages: impl, unit
2026-06-07T23:26:21.0699180Z 
2026-06-07T23:26:21.0699277Z ### REQ-SUBNET-5
2026-06-07T23:26:21.0700483Z - Title: Per-subnet serve-state: spt subnet detach <NAME> [--save] / attach <NAME> [--save] — daemon keeps running, stops/starts advertising + connecting for that subnet (peer pump + responder selective); --save persists the startup default in daemon config; the all-attached banner gains per-subnet states (M8 decision 6, --save renamed from --auto per decision 25 session)
2026-06-07T23:26:21.0701526Z - Required stages: impl, unit
2026-06-07T23:26:21.0701559Z 
2026-06-07T23:26:21.0701654Z ### REQ-SUBNET-6
2026-06-07T23:26:21.0702292Z - Title: Trust lifecycle verbs, elevation-gated: spt subnet leave <NAME> (membership exit) and spt subnet prune <node> (removes a dead identity's trust + registry rows, killing its dead dials; trust mutation = security surface, REQ-PAIR-6 gate machinery) (M8 decisions 6-7)
2026-06-07T23:26:21.0702399Z - Required stages: impl, unit
2026-06-07T23:26:21.0702437Z 
2026-06-07T23:26:21.0702532Z ### REQ-SUBNET-7
2026-06-07T23:26:21.0704100Z - Title: Per-machine re-pair trust overwrite: registry rows carry a hashed stable machine identifier (OS machine id /etc/machine-id|MachineGuid, domain-separated SHA-256 before gossip, spt-minted persisted UUID fallback; additive serde-default field — old rows parse clean); a COMPLETED pairing ceremony presenting the same node label AND machine id as an existing trusted row evicts the superseded identity's trust + registry rows on the seed-holder and replicates the eviction; a gossiped claim alone never evicts trust (M8 decisions 13, 22)
2026-06-07T23:26:21.0704209Z - Required stages: impl, unit
2026-06-07T23:26:21.0704242Z 
2026-06-07T23:26:21.0704333Z ### REQ-SUBNET-8
2026-06-07T23:26:21.0705557Z - Title: Status render honesty: zero-subnet text is daemon-aware ('No subnets registered — this node is standalone.' + daemon-running-dependent blurb, never implying messaging works while the daemon is down); hint footer prints on bare spt subnet only (status drops it); a stalled pump is surfaced in subnet status, never rendered implied-healthy (M8 decisions 11-12, 23)
2026-06-07T23:26:21.0705742Z - Required stages: impl, unit
2026-06-07T23:26:21.0705770Z 
2026-06-07T23:26:21.0705866Z ### REQ-INSTALL-6
2026-06-07T23:26:21.0707064Z - Title: Linux elevation install leg: install.sh symlinks the binary into a sudo-reachable path (/usr/local/bin; graceful print-the-one-liner when unelevated) so sudo spt resolves; first sudo spt detects elevation and prompts ONCE for the default user account — thereafter any elevated daemon launch runs daemon + state under that account, never root (KH 5.7 interplay verified) (M8 decision 8)
2026-06-07T23:26:21.0707298Z - Required stages: impl, unit
2026-06-07T23:26:21.0707331Z 
2026-06-07T23:26:21.0707426Z ### REQ-INSTALL-7
2026-06-07T23:26:21.0708524Z - Title: Windows inbound reachability: the elevated install leg registers the inbound-UDP firewall rule (New-NetFirewallRule); the daemon self-detects blocked inbound and renders it as the no-connection state in subnet status + the coming-online banner (covers user-scope installs that skip the elevated leg — never a silent NO_SEED_HOLDER dead-end) (M8 root cause 3)
2026-06-07T23:26:21.0708642Z - Required stages: impl
2026-06-07T23:26:21.0708671Z 
2026-06-07T23:26:21.0708767Z ### REQ-INSTALL-8
2026-06-07T23:26:21.0709736Z - Title: OS-service registration (REQ-INSTALL-1's deferred third leg): Linux systemd USER service + loginctl enable-linger (linger rides the elevated install leg; daemon starts at boot pre-login, user universe per KH 5.7, systemctl --user managed); Windows scheduled task at-logon (interactive session, no stored credentials); a node is reachable after reboot without any manual spt invocation (M8 decision 17)
2026-06-07T23:26:21.0709841Z - Required stages: impl
2026-06-07T23:26:21.0709869Z 
2026-06-07T23:26:21.0709964Z ### REQ-CONV-1
2026-06-07T23:26:21.0711300Z - Title: Peer address seeding, both cold starts: durable peer-addrs.json (identity dir) maps peer pubkey → last-known dialable address; the pump's resolver consults it FIRST with id-only discovery fallback on miss or dial failure (a stale addr never strands a peer); written by the pairing ceremony (both sides, from the live connection) and by the pump on successful connect; post-join first sync and post-restart resync converge in seconds, not ~1 min (M8 decisions 14, 20)
2026-06-07T23:26:21.0711509Z - Required stages: impl, unit
2026-06-07T23:26:21.0711543Z 
2026-06-07T23:26:21.0711634Z ### REQ-CONV-2
2026-06-07T23:26:21.0712639Z - Title: Event-driven advertisement: endpoint online/offline transitions (ready-listener start/stop, rest-state transition, perch death) trigger an immediate advertise_local + peer push as a WAKE of the existing pump loop (no second advertisement path — epoch lease + visibility gates ride unchanged); the cadence stays the steady-state floor (M8 decision 15)
2026-06-07T23:26:21.0712744Z - Required stages: impl, unit
2026-06-07T23:26:21.0712777Z 
2026-06-07T23:26:21.0712877Z ### REQ-PAIR-8
2026-06-07T23:26:21.0714079Z - Title: NTP TOTP offset: the pairing ceremony queries NTP at ceremony time (both sides) and applies the derived offset to the TOTP calculation in-process only; system-clock fallback when NTP is unreachable (offline LAN pairing unaffected — NTP failure never blocks a pairing that succeeds today); never sets the OS clock; no background sync loop (M8 decision 18; field trigger: enlyzeam clock >1 min off exceeds the ±1 window)
2026-06-07T23:26:21.0714184Z - Required stages: impl, unit
2026-06-07T23:26:21.0714223Z 
2026-06-07T23:26:21.0714322Z ### REQ-DAEMON-5
2026-06-07T23:26:21.0715682Z - Title: Pump liveness: the peer pump writes a last-tick heartbeat consumed by daemon status / subnet status (decision 23 render legs in REQ-CLI-2/REQ-SUBNET-8); the daemon supervises the pump task — a panic is caught, logged loudly, and the pump restarts with capped backoff (≤5 min), so a 5.9-class death self-heals visibly instead of silently halving the daemon (M8 decision 23; field motivation: hfenduleam 2026-06-07 half-death)
2026-06-07T23:26:21.0715802Z - Required stages: impl, unit
2026-06-07T23:26:21.0715831Z 
2026-06-07T23:26:21.0715934Z ### REQ-HAZARD-EPOCH-RESET
2026-06-07T23:26:21.0717254Z - Title: Advertisement-epoch reset strands a node: peers' higher last-seen epoch drops the reset node's fresh advertisements as Stale until the counter outruns history. Common case (full reinstall/re-pair) is mitigated by REQ-SUBNET-7's ceremony eviction (peer-side epoch memory dies with the deleted row — acceptance-verified); the residual narrow slice (epoch file lost, identity kept) is documented, guard deferred to a field hit (4.11)
2026-06-07T23:26:21.0717493Z - Required stages: 
2026-06-07T23:26:21.0717525Z 
2026-06-07T23:26:21.0717619Z ## How to report back
2026-06-07T23:26:21.0717657Z 
2026-06-07T23:26:21.0717825Z For every (requirement, failing criterion) pair, emit one finding:
2026-06-07T23:26:21.0717859Z 
2026-06-07T23:26:21.0717943Z     {
2026-06-07T23:26:21.0718049Z       "code": "requirement_quality",
2026-06-07T23:26:21.0718163Z       "requirementId": "REQ-...",
2026-06-07T23:26:21.0718315Z       "criterion": "singular" | "verifiable" | "atomic" | "active-voice",
2026-06-07T23:26:21.0718412Z       "message": "<short reason>",
2026-06-07T23:26:21.0718540Z       "suggestedRevision": "<optional rewrite>"
2026-06-07T23:26:21.0718621Z     }
2026-06-07T23:26:21.0718654Z 
2026-06-07T23:26:21.0718826Z Wrap your response as { "findings": [ ... ] } listing only your concerns; the
2026-06-07T23:26:21.0718974Z deterministic findings above don't need to be repeated.
